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DETAILED ACTION 

1. Claims 1, 3, 5, 8-11, 13, 15, and 18-22 are pending. 

2. The office acknowledges the following papers: 
Claims arguments filed on 1 0/26/2007. 

New Claim Rejections - 35 USC § 103 

3. The following is a quotation of 35 U.S.C. §1 03(a) which forms the basis for all 

obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

4. Claim 9 is rejected under 35 U.S.C. §1 03(a) as being unpatentable over Terada 
et al. (U.S. 6,041,399), in view of Blaner et al. (U.S. 5,659,722), in view of Weaver et al. 
("The SPARC Architecture Manual: Version 9"). 

5. As per claim 9: 

Terada disclosed .a method of executing an instruction defined by an opcode and 
having a reference to a register, an immediate value, and a control bit that dictates one 
of at least two tests, the method comprising: 

Examining said control bits to determine its state (Terada: Figure 4, column 5 
lines 66-67 continued to column 6 lines 1-24)(The opcode of the instruction specifies 
how the instruction will execute, which equates to the control bits.); 

If said control bits are in a first state, comparing the immediate value to the 
contents of the register referenced in the instruction and skipping a subsequent 
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instruction based on the outcome of the comparison (Terada: Figure 4, column 5 lines 
66-67 continued to column 6 lines 1-24)(The compare instruction in figure 4 is done by 
comparing the data stored in the specified register to the immediate value. The register 
is a normal register within the register file and is not the status register. Thus having the 
same functionality.); or 

Terada failed to teach if said control bit is in a second state, masking the 
contents of the register with the immediate value, testing one or more bits in the masked 
version of the contents of the register, and skipping a subsequent instruction based on 
the outcome of the testing; and wherein said control bit is outside said opcode. 

However, Blaner disclosed if said control bits are in a second state, masking the 
contents of the register with the immediate value, testing one or more bits in the masked 
version of the contents of the register, and skipping a subsequent instruction based on 
the outcome of the testing (Blaner: Figures 3 and 7, column 4 lines 53-67 continued to 
column 5 lines 1-42 and column 6 lines 26-39 and column 8 lines 4-31)(The test and 
branch instruction's opcode states that the comparison is done between the status 
register and the immediate predicate value within the instruction, which is element 508 
in figure 3. Figure 7 shows the process of executing this instruction. Element 330 is the 
status register that stores the current status bits that are checked by the branch 
instruction. Column 8 discusses the process of masking the immediate mask in the 
instruction with the status register values to determine test value. This test value is the 
basis of if the branch is taken or not.). 
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Processing elements produce condition signals during execution that indicate 
conditions relevant to the execution of an instruction. These signals can later be used 
by conditional branches to determine if certain conditions were met for a branch 
instruction (Blaner: Column 1 lines 20-29). This type of branch instruction that performs 
a mask of the status bits with an immediate value to determine if the branch is taken 
would also be useful in other processors, such as the processor of Terada. The 
advantage of having conditional branches that branch on the status bits generated from 
prior instructions would have motivated one of ordinary skill in the art at the time of the 
invention to implement the test and branch instruction of Blaner into the processor of 
Terada. Thus, it would have been obvious to one of ordinary skill in the art at the time 
of the invention to add the test and branch instruction to Terada for the benefits of 
branching dependent on different status bits generated from previous instructions. 

Terada and Blaner failed to teach al control bit that specifies a first or second 
state and wherein said control bit is outside said opcode. 

However, Weaver disclosed a control bit that specifies a first or second state and 
wherein said control bit is outside said opcode (Weaver: Figure 33, pages 64, 138-139, 
and 146-1 50)(The SPARC manual shows branch instructions with a common opcode 
and a rcond code that specifies a specific type of branch instruction. The combination 
with Terada and Blaner allows for the two instructions to share an opcode and have 
control bits outside of the opcode to specify which operation will execute. An individual 
bit within the rcond code allows for the selection of two operations given the other bits 
are the same value.). 
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The advantage of using control bits outside of an instruction opcode to specify 
execution is that is can be used to expand a processor's instruction set architecture for 
operations that have unused bits in their instruction encoding. One of ordinary skill in 
the art would have been motivated by this to allow for control bits outside of the 
instruction opcode to specify different operations for the advantage of expanding a 
processor's instruction set architecture. Thus, it would have been obvious to one of 
ordinary skill in the art at the time of the invention to implement control bits outside of 
the instruction opcode for the advantage of expanding a processor's instruction set 
architecture. 

6. Claim 10 is rejected under 35 U.S.C. §1 03(a) as being unpatentable overTerada 
et al. (U.S. 6,041 ,399), in view of Blaner et al. (U.S. 5,659,722), in view of Weaver et.al. 
("The SPARC Architecture Manual: Version 9"), further in view of Chen et al. (U.S. 
5,504,903) 

7. As per claim 10: 

Terada, Blaner, and Weaver disclosed the method of claim 9. 

Terada, Blaner, and Weaver failed to teach wherein skipping the subsequent 
instruction comprises replacing the subsequent instruction with a no operation 
instruction. 

However, Chen disclosed wherein skipping the subsequent instruction comprises 
replacing the subsequent instruction with a no operation instruction (Chen: Column 7 
lines 59-67 continued to column 8 lines 1-3). 
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Both the bit test and skip if set/clear instructions are essentially a predicated compare 
instruction, which will only execute the next instruction if a condition is met. If the 
condition is met, then the next instruction is not allowed to complete and is essentially 
the same as a nop instruction. Thus, it would have been obvious to one of ordinary skill 
in the art to use the process from Chen of substituting in a nop instruction instead of the 
instruction from Blaner or Terada that will simply not complete if the condition to not 
execute is met. 

8. Claims 1, 3, 5, 8, and 21 are rejected under 35 U.S.C. §1 03(a) as being 
unpatentable over Terada et al. (U.S. 6,041,399), in view of Ramasamy et al. (U.S. 
6,931,632), in view of Blaner et al. (U.S. 5,659,722), in view of Weaver et al. ("The 
SPARC Architecture Manual: Version 9"). 

9. As per claim 1: 

Terada disclosed a processor executing a plurality of instructions, comprising: 

An arithmetic logic unit (Terada: Figure 1 elements 103-104 and 203-204, 
column 5 lines 35-51); and 

A plurality of registers coupled to the ALU, each register programmable to store a 
register value (Terada: Figure 1 elements 102 and 202, column 5 lines 52-61); 

Wherein said processor executes a routine having a test and skip instruction 
defined by an opcode, said instruction includes an immediate value and a reference to a 
register, the test and skip instruction performs a comparison using the immediate value 
and the register value stored in the referenced register, and selectively skips a 
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subsequent instruction that follows the test and skip instruction based on the 
comparison (Terada: Figure 4, column 5 lines 66-67 continued to column 6 lines 1- 
24)(lt's obvious to one of ordinary skill in the art that the instructions contained within 
figure 4 could occur within a routine. The compare greater than instruction in figure 4 
compares a register value to an immediate value. The predicate result of this will cause 
the subtraction instruction to execute or execute and not save the results of the 
instruction to a register. Thus having the same functionality.). 

Wherein the test and skip instruction includes at least one bit that specifies 
whether the register reference is to a register from a first group of registers or to a 
register from a second group of registers (Terada: Figure 4, column 5 lines 66-67 
continued to column 6 lines 1-24)(The first group of registers is registers from the 
register file and the second group of registers is the status register. The compare 
instruction's opcode specifies that a comparison will be done by a normal register and 
not a status register. Thus having the same functionality.); and if a register from the first 
group of registers is specified by said at least one bit, the comparison is performed by 
comparing the immediate value to the register value (Terada: Figure 4, column 5 lines 
66-67 continued to column 6 lines 1-24)(The compare instruction in figure 4 is done by 
comparing the data stored in the register to the immediate value. Thus having the same 
functionality.). 

Terada failed to teach if a register from the second group of registers is specified 
by said at least one bit, the comparison is performed by masking the register value with 
the immediate value and examining one or more bits in the masked version of the 
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referenced register and wherein the subsequent instruction jumps to another routine. 

However, Ramasamy disclosed wherein the subsequent instruction jumps to 
another routine (Ramasamy: Column 1 lines 38-45)(Ramasamy disclosed a predicated 
branch instruction that relies on a predicated value to determine if the branch instruction 
is taken or not. Since the branch is a call instruction, it jumps to another routine.). 

The use of a predicated branch instruction has the same result of a conditional 
branch instruction, which both result in branching to the target address if a particular 
condition is met. Thus, it's obvious to one of ordinary skill in the art at the time of the 
invention that each of these methods could be used intertwined to achieve the same 
result. 

Terada and Ramasamy failed to teach if a register from the second group of 
registers is specified by said at least one bit, the comparison is performed by masking 
the register value with the immediate value and examining one or more bits in the 
masked version of the referenced register. 

However, Blaner disclosed if a register from the second group of registers is 
specified by said bit, the comparison is performed by masking the register value with the 
immediate value and examining one or more bits in the masked version of the 
referenced register (Blaner: Figures 3 and 7, column 4 lines 53-67 continued to column 
5 lines 1-42 and column 6 lines 26-39 and column 8 lines 4-31)(The test and branch 
instruction's opcode states that the comparison is done between the status register and 
the immediate predicate value within the instruction, which is element 508 in figure 3. 
Figure 7 shows the process of executing this instruction. Element 330 is the status 
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register that stores the current status bits that are checked by the branch instruction. 
Column 8 discusses the process of masking the immediate mask in the instruction with 
the status register values to determine test value. This test value is the basis of if the 
branch is taken or not.). 

Processing elements produce condition signals during execution that indicate 
conditions relevant to the execution of an instruction. These signals can later be used 
by conditional branches to determine if certain conditions were met for a branch 
instruction (Blaner: Column 1 lines 20-29). This type of branch instruction that performs 
a mask of the status bits with an immediate value to determine if the branch is taken 
would also be useful in other processors, such as the processor of Terada. The 
advantage of having conditional branches that branch on the status bits generated from 
prior instructions would have motivated one of ordinary skill in the art at the time of the 
invention to implement the test and branch instruction of Blaner into the processor of 
Terada. Thus, it would have been obvious to one of ordinary skill in the art at the time 
of the invention to add the test and branch instruction to Terada for the benefits of 
branching dependent on different status bits generated from previous instructions. 

Terada, Ramasamy, and Blaner failed to teach an instruction with a control bit to 
control two different modes of comparison and wherein the test and skip instruction 
includes at least one bit, separate from the opcode. 

However, Weaver disclosed an instruction with a control bit to control two 
different modes of comparison and wherein the test and skip instruction includes at 
least one bit, separate from the opcode (Weaver: Figure 33, pages 64, 138-139, and 
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146-150)(The SPARC manual shows branch instructions with a common opcode and a 
rcond code that specifies a specific type of branch instruction. The combination with 
Terada and Blaner allows for the two instructions to share an opcode and have control 
bits outside of the opcode to specify which operation will execute. An individual bit 
within the rcond code allows for the selection of two operations given the other bits are 
the same value.). 

The advantage of using control bits outside of an instruction opcode to specify 
execution is that is can be used to expand a processor's instruction set architecture for 
operations that have unused bits in their instruction encoding. One of ordinary skill in 
the art would have been motivated by this to allow for control bits outside of the 
instruction opcode to specify different operations for the advantage of expanding a 
processor's instruction set architecture. Thus, it would have been obvious to one of 
ordinary skill in the art at the time of the invention to implement control bits outside of 
the instruction opcode for the advantage of expanding a processor's instruction set 
architecture. 
10. As per claim 3: 

Terada, Ramasamy, Blaner, and Weaver disclosed the processor of claim 1 
wherein, if comparing the immediate value to the register value, the processor skips the 
subsequent instruction if the immediate value does not match the register value and 
executes the subsequent if the immediate value does match the register value (Terada: 
Figure 11, column 5 lines 66-67 continued to column 6 lines 1-24 and column 7 lines 
39-48)(Figure 1 1 shows a compare equal instruction that compares a immediate value 
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to a register value. The following instruction in figure 1 1 is skipped if the results aren't 
equal and is executed if they are equal. Thus having the same functionality.) 

11. As per claim 5: 

Terada, Ramasamy, Blaner, and Weaver disclosed the processor of claim 1 
wherein, if masking the register value, the masking is performed by ANDing the 
immediate value with the register value (Blaner: Figure 7 elements 352, 362, 372, and 
382, column 8 lines 4-31)(These elements are ANDing the value from the status register 
with the immediate value of the predicate from the branch instruction.). 

12. As per claim 8: 

Terada, Ramasamy, Blaner, and Weaver disclosed the processor of claim 1 

Wherein the registers include a status register (Blaner: Figure 5, column 7 lines 
1-33)(The multiple predicate register stores predicate value for instructions that don't 
have an immediate predicate value and also stores status bits for each processing 
element. Thus having the same functionality.); and 

If the register reference specified by said at least one bit is not the status register, 
the comparison is performed by comparing the immediate value to the register value in 
the referenced register (Terada: Figure 4, column 5 lines 66-67 continued to column 6 
lines 1-24)(The compare instruction in figure 4 is done by comparing the data stored in 
the specified register to the immediate value. The register is a normal register within 
the register file and is not the status register. Thus having the same functionality.) 

If the register reference specified by said at least one bit is the status register, the 
comparison is performed by masking the register value in the status register with the 
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immediate value and examining one or more bits in the masked version of the status 
register (Blaner: Figures 3 and 7, column 4 lines 53-67 continued to column 5 lines 1-42 
and column 6 lines 26-39 and column 8 lines 4-31)(The test and branch instruction's 
opcode states that the comparison is done between the status register and the 
immediate predicate value within the instruction, which is element 508 in figure 3. 
Figure 7 shows the process of executing this instruction. Element 330 is the status 
register that stores the current status bits that are checked by the branch instruction. 
Column 8 discusses the process of masking the immediate mask in the instruction with 
the status register values to determine test value. This test value is the basis of if the 
branch is taken or not.). 

It would have been obvious to one of ordinary skill in the art that having an 
instruction with two different modes of operation using a control bit is essentially the 
same as having two different instructions using two separate opcodes to control two 
different modes of operation. Thus, it would have been obvious to one of ordinary skill 
in the art at the time of the invention to combine the two instructions and use a single 
control bit in the opcode to differentiate between the two modes of execution. In 
addition, according to "In re Larson" (144 USPQ 374 (CCPA 1965)), to make integral 
doesn't give patentability over prior art.). 
13. As per claim 21: 

Terada, Ramasamy, Blaner, and Weaver disclosed the processor of claim 1 
wherein, if masking the register value, the processor skips the subsequent instruction if 
the masked version of the register value comprises all logic high values or all logic low 
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values, and executes the subsequent instruction if the masked version comprises a mix 
of logic high and low values (Blaner: Figures 3 and 7, column 4 lines 53-67 continued 
to column 5 lines 1-42, column 6 lines 26-39, and column 8 lines 4-31)(Column 8 
discusses the process of masking the immediate mask in the instruction with the status 
register values to determine test value. This test value is the basis of if the branch is 
taken or not At line 25, a branch occurs if all values are high. Blaner only discusses 
using an AND or an OR circuit to determine branching based on the masked values. 
One of ordinary skill in the art would realize that other logic gates can be useful for 
masking values to get a certain result, such as NOT, XOR, and XNOR gates. An XNOR 
gate will output a 1 value if all values are either 0 or 1 and will output a 0 value if there's 
a mix of 0's and 1 's. It's obvious to one of ordinary skill in the art that these gates are 
able to be substituted to get to a specific solution. Thus, it's obvious to one of ordinary 
skill in the art to substitute the XNOR gate for the AND and OR gates used within 
Blaner.). 

14. Claims 11, 13, 15, 18, and 22 are rejected under 35 U.S.C. §103(a) as being 
unpatentable over Terada et al. (U.S. 6,041 ,399), in view of Feierbach et al. (U.S. 
6,088,786), in view of Blaner etal. (U.S. 5,659,722), in view of Weaver et al. ("The 
SPARC Architecture Manual: Version 9"). 

15. As per claim 11: 

Terada disclosed a system, comprising: 

A main processor unit (Terada: Figure 16 figure 20, column 10 lines 43-49); and 
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A co-processor coupled to said main processor unit (Terada: Figure 16 element 
22, column 10 lines 43-49); 

Wherein, during the register-based instruction mode, the coprocessor executes 
an instruction defined by an opcode and including an immediate value and a reference 
to a register accessible to said co-processor, performs a comparison using the 
immediate value and the register value, and executes or skips a subsequent instruction 
based on the comparison (Terada: Figure 4, column 5 lines 66-67 continued to column 
6 lines 1-24)(The compare greater than instruction in figure 4 compares a register value 
to an immediate value. The predicate result of this will cause the subtraction instruction 
to execute or execute and not save the results of the instruction to a register. Thus 
having the same functionality. Since the instruction deals with registers, the 
coprocessor executes the comparison instruction in a register-based mode.). 

Wherein the instruction includes at least one bit that specifies whether the 
register reference is to a register from a first group of registers or to a register from a 
second group of registers (Terada: Figure 4, column 5 lines 66-67 continued to column 
6 lines 1-24)(The first group of registers is registers from the register file and the second 
group of registers is the status register. The compare instruction's opcode specifies that 
a comparison will be done by a normal register and not a status register. Thus having 
the same functionality.) and if a register from the first group of registers is specified by' 
said at least one bit, the comparison is performed by comparing the immediate value to 
the register value (Terada: Figure 4, column 5 lines 66-67 continued to column 6 lines 
1-24)(The compare instruction in figure 4 is done by comparing the data stored in the 
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register to the immediate value. Thus having the same functionality.). 

Terada failed to teach if a register from the second group of registers is specified 
by said at least one bit, the comparison is performed by masking the register value with 
the immediate value and examining one or more bits in the masked version of the 
referenced register and wherein said co-processor selectively operates in a stack-based 
instruction mode and a register-based instruction mode. 

However, Feierbach disclosed wherein said co-processor selectively operates in 
a stack-based instruction mode and a register-based instruction mode (Feierbach: 
Figure 2 element 227, column 7 lines 27-37)(Figure 2 shows a processor that is able to 
selectively execute stack-based instructions and register-based instructions by using a 
predecoder, element 227, to determine where the current instruction is to go.). 

The advantage of stack-based processors is that they are much more compact 
and efficient than there register-based counterparts. Having both a stack-based and 
register-based processor is advantageous when a processor also has to occasionally 
execute high-performance multimedia applications, which are better suited for register- 
based processors (Feierbach: Column 2 lines 44-67 continued to column 3 lines 1-45). 
One of ordinary skill in the art would have been motivated by the increased performance 
in certain applications for stack-based processors to add a stack-based processor to the 
processor of Terada. Thus, it would have been obvious to one of ordinary skill in the art 
at the time of the invention to implement a stack-based processor alongside the 
register-based processor of Terada for the advantage of increased performance in 
certain applications. 
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Terada and Feierbach failed to teach if a register from the second group of 
registers is specified by said at least one bit, the comparison is performed by masking 
the register value with the immediate value and examining one or more bits in the 
masked version of the referenced register. 

However, Blaner disclosed if a register from the second group of registers is 
specified by said bit, the comparison is performed by masking the register value with the 
immediate value and examining one or more bits in the masked version of the 
referenced register (Blaner: Figures 3 and 7, column 4 lines 53-67 continued to column 
5 lines 1-42 and column 6 lines 26-39 and column 8 lines 4-31)(The test and branch 
instruction's opcode states that the comparison is done between the status register and 
the immediate predicate value within the instruction, which is element 508 in figure 3. 
Figure 7 shows the process of executing this instruction. Element 330 is the status 
register that stores the current status bits that are checked by the branch instruction. 
Column 8 discusses the process of masking the immediate mask in the instruction with 
the status register values to determine test value. This test value is the basis of if the 
branch is taken or not.). 

Processing elements produce condition signals during execution that indicate 
conditions relevant to the execution of an instruction. These signals can later be used 
by conditional branches to determine if certain conditions were met for a branch 
instruction (Blaner: Column 1 lines 20-29). This type of branch instruction that performs 
a mask of the status bits with an immediate value to determine if the branch is taken 
would also be useful in other processors, such as the processor of Terada. The 
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advantage of having conditional branches that branch on the status bits generated from 
prior instructions would have motivated one of ordinary skill in the art at the time of the 
invention to implement the test and branch instruction of Blaner into the processor of 
Terada. Thus, it would have been obvious to one of ordinary skill in the art at the time 
of the invention to add the test and branch instruction to Terada for the benefits of 
branching dependent on different status bits generated from previous instructions. 

Terada, Feierbach, and Blaner failed to teach an instruction with a control bit to 
control two different modes of comparison and wherein the instruction includes at least 
one bit, separate from said opcode. 

However, Weaver disclosed an instruction with a control bit to control two 
different modes of comparison and wherein the instruction includes at least one bit, 
separate from said opcode (Weaver: Figure 33, pages 64, 138-139, and 146-1 50)(The 
SPARC manual shows branch instructions with a common opcode and a rcond code 
that specifies a specific type of branch instruction. The combination with Terada and 
Blaner allows for the two instructions to share an opcode and have control bits outside 
of the opcode to specify which operation will execute. An individual bit within the rcond 
code allows for the selection of two operations given the other bits are the same value.). 

The advantage of using control bits outside of an instruction opcode to specify 
execution is that is can be used to expand a processor's instruction set architecture for 
operations that have unused bits in their instruction encoding. One of ordinary skill in 
the art would have been motivated by this to allow for control bits outside of the 
instruction opcode to specify different operations for the advantage of expanding a 
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processor's instruction set architecture. Thus, it would have been obvious to one of 
ordinary skill in the art at the time of the invention to implement control bits outside of 
the instruction opcode for the advantage of expanding a processor's instruction set 
architecture. 

16. As per claim 13: 

Claim 13 essentially recites the same limitations of claim 3. Therefore, claim 13 
is rejected for the same reasons as claim 3. 

17. As per claim 15: 

Claim 15 essentially recites the same limitations of claim 5. Therefore, claim 15 
is rejected for the same reasons as claim 5. 

18. As per claim 18: 

Terada, Feierbach, Blaner, and Weaver disclosed the system of claim 11 further 
comprising wireless communication circuitry and said system comprises a cell phone 
(Official notice is taken that the processing system could be part of a^cellular .. 
telephone.). 

19. As per claim 22: 

Claim 22 essentially recites the same limitations of claim 21. Therefore, claim 22 
is rejected for the same reasons as claim 21 . 

20. Claims 19-20 are rejected under 35 U.S.C. §1 03(a) as being unpatentable over 
Terada et al. (U.S. 6,041 ,399), in view of Ramasamy et al. (U.S. 6,931 ,632), in view of 
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Hammond et al. (U.S. 5,638,525), in view of Blaner et al. (U.S. 5,659,722), in view of 
Weaver et al. ("The SPARC Architecture Manual: Version 9"). 
21. As per claim 19: 

Terada disclosed a programmable logic device comprising: 

Control logic (Terada: Figures 1 and 5, columns 5-6); and 

Means for decoding a control bit in an instruction that includes an immediate 
value and a reference to a register for performing a comparison using the immediate 
value and a register value stored in the referenced register, and for causing the 
processor to execute or skip a subsequent instruction that follows the instruction based 
on the comparison (Terada: Figure 4, column 5 lines 66-67 continued to column 6 lines 
1-24)(The compare greater than instruction in figure 4 compares a register value to an 
immediate value. The predicate result of this will cause the subtraction instruction to 
execute or execute and not save the results of the instruction to a register. Thus having 
the same functionality. The compare instruction's opcode contains control bits that 
specifies a comparison will be done by a normal register and not a status register.). 

Wherein said control bit selectively specifies whether the comparison is to be 
performed by comparing the immediate value to the register vafue (Terada: Figure 4, 
column 5 lines 66-67 continued to column 6 lines 1-24)(The first group of registers is 
registers from the register file and the second group of registers is the status register. 
The compare instruction's opcode specifies that a comparison will be done by a normal 
register and not a status register. Thus having the same functionality.). 

Terada failed to teach means for selectively changing an operating mode of the 
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programmable logic device; whether the comparison is to be performed by masking the 
register value with the immediate value and examining one or more bits in the masked 
version of the referenced register; and wherein the subsequent instruction jumps to a 
routine associated with a particular operating mode. 

However, Ramasamy disclosed wherein the subsequent instruction jumps to a 
routine (Ramasamy: Column 1 lines 38-45)(Ramasamy disclosed a predicated branch 
instruction that relies on a predicated value to determine if the branch instruction is 
taken or not. Since the branch is a call instruction, it jumps to another routine.). 

The use of a predicated branch instruction has the same result of a conditional 
branch instruction, which both result in branching to the target address if a particular 
condition is met. Thus, it's obvious to one of ordinary skill in the art at the time of the 
invention that each of these methods could be used intertwined to achieve the same 
result. 

Terada and Ramasamy failed to teach means for selectively changing an 
operating mode of the programmable logic device and whether the comparison is to be 
performed by masking the register value with the immediate value and examining one . 
or more bits in the masked version of the referenced register. 

However, Hammond disclosed means for selectively changing an operating 
mode of the programmable logic device (Hammond: Figure 2 element 212, column 4 
lines 61-67 continued to column 5 lines 1-19)(The switch instruction changes the 
processor from one operating mode to the other.); and 

Wherein the subsequent instruction jumps to a routine associated with a 
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particular operating mode (Hammond: Figure 2 element 212, column 4 lines 61-67 
continued to column 5 lines 1-19)(Ramasamy: Column 1 lines 38-45)(The combination 
of Hammond and Ramasamy result in the jump switch instruction of Hammond being a 
predicated branch instruction.). 

The advantage of using multiple instruction sets for a processor is that it allows 
for increased flexibility in what type of programs the processor can execute. One of 
ordinary skill in the art would have been motivated by this to implement a processor with 
multiple ISA's. Thus, it would have been obvious to one of ordinary skill in the art at the 
time of the invention to implement a processor with multiple instruction set architectures 
for the advantage of increased flexibility in the type of programs that the processor is 
able to execute. 

Terada, Ramasamy, and Hammond failed to teach whether the comparison is to 
be performed by masking the register value with the immediate value and examining 
one or more bits in the masked version of the referenced register. 

However, Blaner disclosed whether the comparison is to be performed by 
masking the register value with the immediate value and examining one or more bits in 
the masked version of the referenced register (Blaner: Figures 3 and 7, column 4 lines 
53-67 continued to column 5 lines 1-42 and column 6 lines 26-39 and column 8 lines 4- 
31)(The test and branch instruction's opcode states that the comparison is done 
between the status register and the immediate predicate value within the instruction, 
which is element 508 in figure 3. Figure 7 shows the process of executing this 
instruction. Element 330 is the status register that stores the current status bits that are 
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checked by the branch instruction. Column 8 discusses the process of masking the 
immediate mask in the instruction with the status register values to determine test value. 
This test value is the basis of if the branch is taken or not.). 

Processing elements produce condition signals during execution that indicate 
conditions relevant to the execution of an instruction. These signals can later be used 
by conditional branches to determine if certain conditions were met for a branch 
instruction (Blaner: Column 1 lines 20-29). This type of branch instruction that performs 
a mask of the status bits with an immediate value to determine if the branch is taken 
would also be useful in other processors, such as the processor of Terada. The 
advantage of having conditional branches that branch on the status bits generated from 
prior instructions would have motivated one of ordinary skill in the art at the time of the 
invention to implement the test and branch instruction of Blaner into the processor of 
Terada. Thus, it would have been obvious to one of ordinary skill in the art at the time 
of the invention to add the test and branch instruction to Terada for the benefits of 
branching dependent on different status bits generated from previous instructions. 

Terada, Ramasamy, Hammond, and Blaner failed to teach an instruction with a 
control bit to control two different modes of comparison and wherein said control bit is 
separate from an opcode that defines said instruction. 

However, Weaver disclosed an instruction with a control bit to control two 
different modes of comparison and wherein said control bit is separate from an opcode 
that defines said instruction (Weaver: Figure 33, pages 64, 138-139, and 146-150)(The 
SPARC manual shows branch instructions with a common opcode and a rcond code 
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that specifies a specific type of branch instruction. The combination with Terada and 
Blaner allows for the two instructions to share an opcode and have control bits outside 
of the opcode to specify which operation will execute. An individual bit within the rcond 
code allows for the selection of two operations given the other bits are the same value.). 

The advantage of using control bits outside of an instruction opcode to specify 
execution is that is can be used to expand a processor's instruction set architecture for 
operations that have unused bits in their instruction encoding. One of ordinary skill in 
the art would have been motivated by this to allow for control bits outside of the 
instruction opcode to specify different operations for the advantage of expanding a 
processor's instruction set architecture. Thus, it would have been obvious to one of 
ordinary skill in the art at the time of the invention to implement control bits outside of 
the instruction opcode for the advantage of expanding a processor's instruction set 
architecture. 
22. As per claim 20: 

Terada, Ramasamy, Hammond, Blaner, and Weaver disclosed the system of 
claim 19 including means for comparing the immediate value to the register value in the 
referenced register (Terada: Figure 4, column 5 lines 66-67 continued to column 6 lines 
1-24)(The compare greater than instruction in figure 4 compares a register value to an 
immediate value. The predicate result of this will cause the subtraction instruction to 
execute or execute and not save the results of the instruction to a register. Thus having 
the same functionality.). 



Application/Control Number: 10/632,214 Page 24 

Art Unit: 2183 

Response to Arguments 

23. The arguments presented by Applicant in the response, received on 10/26/2007 
are not considered persuasive. 

24. Applicant argues that "The combination of Terada and Blaner doesn't result an a 
control bit outside of an instruction opcode that performs two claimed functions based 
on such a bit" for claims 1,9,11, and 1 9. 

This argument is found to be persuasive for the following reason. The examiner 
agrees that the amendment failed to teach the newly claimed limitations. However, a 
new ground of rejection has been given. 

In addition, the examiner's reliance on In re Larson is no longer used. Thus, any 
arguments against it are moot. 

Conclusion 

The following is text cited from 37 CFR 1.111 (c): In amending in reply to a 
rejection of claims in an application or patent under reexamination, the applicant or 
patent owner must clearly point out the patentable novelty which he or she thinks the 
claims present in view of the state of the art disclosed by the references cited or the 
objections made. The applicant or patent owner must also show how the amendments 
avoid such references or objections. 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Jacob Petranek whose telephone number is 571-272- 
5988. The examiner can normally be reached on M-F 8:00-4:30. 
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If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Eddie Chan can be reached on (571) 272-4162. The fax phone number for 
the organization where this application or proceeding is assigned is 703-872-9306. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 



Jacob Petranek 
Examiner, Art Unit 2183 




